---
title: '引用 (Refs)'
description: '实现越界 DOM 访问'
---

`ref` 关键字可以在任何 HTML 元素或组件中使用，以获取附加到该元素的 DOM `Element`。这可以用于在 `view` 生命周期方法之外对 DOM 进行更改。

这对于获取 canvas 元素或滚动到页面的不同部分很有用。例如，在组件的 `rendered` 方法中使用 `NodeRef` 允许您在从 `view` 渲染后对 canvas 元素进行绘制调用。

语法如下：

```rust
use web_sys::Element;
use yew::{html, Component, Context, Html, NodeRef};

struct Comp {
    node_ref: NodeRef,
}

impl Component for Comp {
    type Message = ();
    type Properties = ();

    fn create(_ctx: &Context<Self>) -> Self {
        Self {
            // highlight-next-line
            node_ref: NodeRef::default(),
        }
    }

    fn view(&self, _ctx: &Context<Self>) -> Html {
        html! {
            // highlight-next-line
            <div ref={self.node_ref.clone()}></div>
        }
    }

    fn rendered(&mut self, _ctx: &Context<Self>, _first_render: bool) {
        // highlight-start
        let has_attributes = self.node_ref
            .cast::<Element>()
            .unwrap()
            .has_attributes();
        // highlight-end
    }
}
```

## 相关示例

- [节点引用](https://github.com/yewstack/yew/tree/master/examples/node_refs)
